home *** CD-ROM | disk | FTP | other *** search
/ Creative Computers / Creative Computers CD-ROM, Volume 1 (Legendary Design Technologies, Inc.)(1994).iso / shareware / management / taske_37.1 / source / taske.c < prev    next >
C/C++ Source or Header  |  1994-11-17  |  7KB  |  277 lines

  1. /*
  2.  *  Source machine generated by GadToolsBox V2.0b
  3.  *  which is (c) Copyright 1991-1993 Jaba Development
  4.  *
  5.  *  GUI Designed by : Michael D. Bayne
  6.  */
  7.  
  8. #include <exec/types.h>
  9. #include <intuition/intuition.h>
  10. #include <intuition/classes.h>
  11. #include <intuition/classusr.h>
  12. #include <intuition/imageclass.h>
  13. #include <intuition/gadgetclass.h>
  14. #include <libraries/gadtools.h>
  15. #include <graphics/displayinfo.h>
  16. #include <graphics/gfxbase.h>
  17. #include <clib/exec_protos.h>
  18. #include <clib/intuition_protos.h>
  19. #include <clib/gadtools_protos.h>
  20. #include <clib/graphics_protos.h>
  21. #include <clib/utility_protos.h>
  22. #include <string.h>
  23. #include <clib/diskfont_protos.h>
  24.  
  25. #include "TaskE.h"
  26.  
  27. struct Screen         *Scr = NULL;
  28. UBYTE                 *PubScreenName = NULL;
  29. APTR                   VisualInfo = NULL;
  30. struct Window         *TaskEWnd = NULL;
  31. struct Gadget         *TaskEGList = NULL;
  32. struct Menu           *TaskEMenus = NULL;
  33. struct IntuiMessage    TaskEMsg;
  34. struct Gadget         *TaskEGadgets[4];
  35. UWORD                  TaskELeft = 0;
  36. UWORD                  TaskETop = 12;
  37. UWORD                  TaskEWidth = 363;
  38. UWORD                  TaskEHeight = 89;
  39. UBYTE                 *TaskEWdt = (UBYTE *)"Task Exchange";
  40. struct TextAttr       *Font, Attr;
  41. UWORD                  FontX, FontY;
  42. UWORD                  OffX, OffY;
  43. struct TextFont       *TaskEFont = NULL;
  44.  
  45. struct NewMenu TaskENewMenu[] = {
  46.     NM_TITLE, (STRPTR)"Project", NULL, 0, NULL, NULL,
  47.     NM_ITEM, (STRPTR)"About...", (STRPTR)"?", 0, 0L, (APTR)TaskEABOUT,
  48.     NM_ITEM, (STRPTR)NM_BARLABEL, NULL, 0, 0L, NULL,
  49.     NM_ITEM, (STRPTR)"Quit", (STRPTR)"Q", 0, 0L, (APTR)TaskEQUIT,
  50.     NM_TITLE, (STRPTR)"Kill", NULL, 0, NULL, NULL,
  51.     NM_ITEM, (STRPTR)"Window...", (STRPTR)"W", 0, 0L, (APTR)TaskEKWND,
  52.     NM_ITEM, (STRPTR)"Screen...", (STRPTR)"S", 0, 0L, (APTR)TaskEKSCR,
  53.     NM_END, NULL, NULL, 0, 0L, NULL };
  54.  
  55. UWORD TaskEGTypes[] = {
  56.     LISTVIEW_KIND,
  57.     BUTTON_KIND,
  58.     LISTVIEW_KIND,
  59.     BUTTON_KIND
  60. };
  61.  
  62. struct NewGadget TaskENGad[] = {
  63.     184, 2, 176, 72, NULL, NULL, GD_TASKL, 0, NULL, (APTR)TASKLClicked,
  64.     4, 72, 176, 15, (UBYTE *)"_Reboot the machine", NULL, GD_REBOOT, PLACETEXT_IN, NULL, (APTR)REBOOTClicked,
  65.     4, 2, 176, 72, NULL, NULL, GD_SCREENL, 0, NULL, (APTR)SCREENLClicked,
  66.     184, 72, 176, 15, (UBYTE *)"_Update Task List", NULL, GD_UPDATE, PLACETEXT_IN, NULL, (APTR)UPDATEClicked
  67. };
  68.  
  69. ULONG TaskEGTags[] = {
  70.     (TAG_DONE),
  71.     (GT_Underscore), '_', (TAG_DONE),
  72.     (TAG_DONE),
  73.     (GT_Underscore), '_', (TAG_DONE)
  74. };
  75.  
  76. static UWORD ComputeX( UWORD value )
  77. {
  78.     return(( UWORD )((( FontX * value ) + 4 ) / 8 ));
  79. }
  80.  
  81. static UWORD ComputeY( UWORD value )
  82. {
  83.     return(( UWORD )((( FontY * value ) + 4 ) / 8 ));
  84. }
  85.  
  86. static void ComputeFont( UWORD width, UWORD height )
  87. {
  88.     Forbid();
  89.     Font = &Attr;
  90.     Font->ta_Name = (STRPTR)GfxBase->DefaultFont->tf_Message.mn_Node.ln_Name;
  91.     Font->ta_YSize = FontY = GfxBase->DefaultFont->tf_YSize;
  92.     FontX = GfxBase->DefaultFont->tf_XSize;
  93.     Permit();
  94.  
  95.     OffX = Scr->WBorLeft;
  96.     OffY = Scr->RastPort.TxHeight + Scr->WBorTop + 1;
  97.  
  98.     if ( width && height ) {
  99.         if (( ComputeX( width ) + OffX + Scr->WBorRight ) > Scr->Width )
  100.             goto UseTopaz;
  101.         if (( ComputeY( height ) + OffY + Scr->WBorBottom ) > Scr->Height )
  102.             goto UseTopaz;
  103.     }
  104.     return;
  105.  
  106. UseTopaz:
  107.     Font->ta_Name = (STRPTR)"topaz.font";
  108.     FontX = FontY = Font->ta_YSize = 8;
  109. }
  110.  
  111. int SetupScreen( void )
  112. {
  113.     if ( ! ( Scr = LockPubScreen( PubScreenName )))
  114.         return( 1L );
  115.  
  116.     ComputeFont( 0, 0 );
  117.  
  118.     if ( ! ( VisualInfo = GetVisualInfo( Scr, TAG_DONE )))
  119.         return( 2L );
  120.  
  121.     return( 0L );
  122. }
  123.  
  124. void CloseDownScreen( void )
  125. {
  126.     if ( VisualInfo ) {
  127.         FreeVisualInfo( VisualInfo );
  128.         VisualInfo = NULL;
  129.     }
  130.  
  131.     if ( Scr        ) {
  132.         UnlockPubScreen( NULL, Scr );
  133.         Scr = NULL;
  134.     }
  135. }
  136.  
  137. int HandleTaskEIDCMP( void )
  138. {
  139.     struct IntuiMessage    *m;
  140.     struct MenuItem        *n;
  141.     int            (*func)();
  142.     BOOL            running = TRUE;
  143.  
  144.     while( m = GT_GetIMsg( TaskEWnd->UserPort )) {
  145.  
  146.         CopyMem(( char * )m, ( char * )&TaskEMsg, (long)sizeof( struct IntuiMessage ));
  147.  
  148.         GT_ReplyIMsg( m );
  149.  
  150.         switch ( TaskEMsg.Class ) {
  151.  
  152.             case    IDCMP_REFRESHWINDOW:
  153.                 GT_BeginRefresh( TaskEWnd );
  154.                 GT_EndRefresh( TaskEWnd, TRUE );
  155.                 break;
  156.  
  157.             case    IDCMP_CLOSEWINDOW:
  158.                 running = TaskECloseWindow();
  159.                 break;
  160.  
  161.             case    IDCMP_ACTIVEWINDOW:
  162.                 running = TaskEActiveWindow();
  163.                 break;
  164.  
  165.             case    IDCMP_VANILLAKEY:
  166.                 running = TaskEVanillaKey();
  167.                 break;
  168.  
  169.             case    IDCMP_GADGETUP:
  170.             case    IDCMP_GADGETDOWN:
  171.                 func = ( void * )(( struct Gadget * )TaskEMsg.IAddress )->UserData;
  172.                 running = func();
  173.                 break;
  174.  
  175.             case    IDCMP_MENUPICK:
  176.                 while( TaskEMsg.Code != MENUNULL ) {
  177.                     n = ItemAddress( TaskEMenus, TaskEMsg.Code );
  178.                     func = (void *)(GTMENUITEM_USERDATA( n ));
  179.                     running = func();
  180.                     TaskEMsg.Code = n->NextSelect;
  181.                 }
  182.                 break;
  183.         }
  184.     }
  185.     return( running );
  186. }
  187.  
  188. int OpenTaskEWindow( void )
  189. {
  190.     struct NewGadget    ng;
  191.     struct Gadget    *g;
  192.     UWORD        lc, tc;
  193.     UWORD        wleft = TaskELeft, wtop = TaskETop, ww, wh;
  194.  
  195.     ComputeFont( TaskEWidth, TaskEHeight );
  196.  
  197.     ww = ComputeX( TaskEWidth );
  198.     wh = ComputeY( TaskEHeight );
  199.  
  200.     wleft = ( Scr->Width - ww )/2 - Scr->WBorRight;
  201.     wtop = ( Scr->Height - wh - Scr->WBorTop - Scr->WBorBottom - Font->ta_YSize - 1 )/2;
  202.  
  203.     if ( ! ( TaskEFont = OpenDiskFont( Font )))
  204.         return( 5L );
  205.  
  206.     if ( ! ( g = CreateContext( &TaskEGList )))
  207.         return( 1L );
  208.  
  209.     for( lc = 0, tc = 0; lc < TaskE_CNT; lc++ ) {
  210.  
  211.         CopyMem((char * )&TaskENGad[ lc ], (char * )&ng, (long)sizeof( struct NewGadget ));
  212.  
  213.         ng.ng_VisualInfo = VisualInfo;
  214.         ng.ng_TextAttr   = Font;
  215.         ng.ng_LeftEdge   = OffX + ComputeX( ng.ng_LeftEdge );
  216.         ng.ng_TopEdge    = OffY + ComputeY( ng.ng_TopEdge );
  217.         ng.ng_Width      = ComputeX( ng.ng_Width );
  218.         ng.ng_Height     = ComputeY( ng.ng_Height);
  219.  
  220.         TaskEGadgets[ lc ] = g = CreateGadgetA((ULONG)TaskEGTypes[ lc ], g, &ng, ( struct TagItem * )&TaskEGTags[ tc ] );
  221.  
  222.         while( TaskEGTags[ tc ] ) tc += 2;
  223.         tc++;
  224.  
  225.         if ( NOT g )
  226.             return( 2L );
  227.     }
  228.  
  229.     if ( ! ( TaskEMenus = CreateMenus( TaskENewMenu, GTMN_FrontPen, 0L, TAG_DONE )))
  230.         return( 3L );
  231.  
  232.     LayoutMenus( TaskEMenus, VisualInfo, TAG_DONE );
  233.  
  234.     if ( ! ( TaskEWnd = OpenWindowTags( NULL,
  235.                 WA_Left,    wleft,
  236.                 WA_Top,        wtop,
  237.                 WA_Width,    ww + OffX + Scr->WBorRight,
  238.                 WA_Height,    wh + OffY + Scr->WBorBottom,
  239.                 WA_IDCMP,    LISTVIEWIDCMP|BUTTONIDCMP|IDCMP_MENUPICK|IDCMP_CLOSEWINDOW|IDCMP_ACTIVEWINDOW|IDCMP_VANILLAKEY|IDCMP_REFRESHWINDOW,
  240.                 WA_Flags,    WFLG_DRAGBAR|WFLG_CLOSEGADGET|WFLG_SMART_REFRESH|WFLG_ACTIVATE,
  241.                 WA_Gadgets,    TaskEGList,
  242.                 WA_Title,    TaskEWdt,
  243.                 WA_ScreenTitle,    "Task Exchange",
  244.                 WA_PubScreen,    Scr,
  245.                 TAG_DONE )))
  246.     return( 4L );
  247.  
  248.     SetMenuStrip( TaskEWnd, TaskEMenus );
  249.     GT_RefreshWindow( TaskEWnd, NULL );
  250.  
  251.     return( 0L );
  252. }
  253.  
  254. void CloseTaskEWindow( void )
  255. {
  256.     if ( TaskEMenus      ) {
  257.         ClearMenuStrip( TaskEWnd );
  258.         FreeMenus( TaskEMenus );
  259.         TaskEMenus = NULL;    }
  260.  
  261.     if ( TaskEWnd        ) {
  262.         CloseWindow( TaskEWnd );
  263.         TaskEWnd = NULL;
  264.     }
  265.  
  266.     if ( TaskEGList      ) {
  267.         FreeGadgets( TaskEGList );
  268.         TaskEGList = NULL;
  269.     }
  270.  
  271.     if ( TaskEFont ) {
  272.         CloseFont( TaskEFont );
  273.         TaskEFont = NULL;
  274.     }
  275. }
  276.  
  277.